草庐IT

c++ - TCP分片

全部标签

c - 为什么Golang在Linux上使用libc

Closed.ThisquestiondoesnotmeetStackOverflowguidelines。它当前不接受答案。想改善这个问题吗?更新问题,以便将其作为on-topic用于堆栈溢出。去年关闭。Improvethisquestion通过在centos7中执行ldd/usr/local/go/bin/go,我看到Go使用libc和其他一些运行时库:$ldd/usr/local/go/bin/golinux-vdso.so.1(0x00007fff2c9bd000)libpthread.so.0=>/lib/x86_64-linux-gnu/libpthread.so.0(0x

Go:使用 TCP 连接写入 header

我从这里用以下代码结构实现了一个TCP服务器:http://golang.org/pkg/net/#example_Listener我正在尝试从浏览器pingTCP服务器。TCP服务器能够写入我的浏览器。但是,它无法写入客户端header,因为它未使用HTTP协议(protocol)。如何保持TCP协议(protocol)和连接,但仍然能够写入浏览器的header? 最佳答案 HowdoIkeeptheTCPprotocolandconnectionsbutstillbeabletowritetothebrowser'sheader

go - 在 Golang 中,为什么 conn.Write tcp 响应为空?

我有一个读取文件的tcp服务器,该文件将文件内容发送到客户端。“status.txt”文件仅包含一个bool值。当我curl时,这显示true(带有前导空格)。dat,err:=ioutil.ReadFile("./status.txt")conn.Write([]byte(""+string(dat)))而此代码导致curl:(52)Emptyreplyfromserver。conn.Write([]byte(string(dat)))知道为什么会这样吗?我不想填充我的响应字符串。 最佳答案 如果您不使用HTTP协议(protoc

无法读取 utmpx 文件

packagemainimport("os""fmt")funcmain(){fd,err:=os.Open("/var/run/utmpx")fmt.Println(fd,err)vardata[]bytelen,err:=fd.Read(data)fmt.Println(len,err)}&{0xc42000a240}nil0nil没有错误,也没有数据。这个路径/var/run/utmpx是从系统头文件中读取的。如何得到这个路径是anotherquestion系统:macOSelcapiton,go版本go1.8darwin/amd64**我的最终目标是将此文件读入gostruct

Golang TCP 服务器读取 HTTP/2 帧

我正在尝试设置一个接受和解码HTTP/2数据的TCP服务器。实际解析帧的代码可以在这篇文章中找到:Decodinghttp2frameheader/datainGo但是,我在设置服务器时遇到了问题。连接被接受,但它卡在framer.ReadFrame()上。这是一个代码示例://generatewith:opensslreq-x509-newkeyrsa:4096-keyoutserver.key-outserver.pem-days365-nodescert,err:=tls.LoadX509KeyPair("server.pem","server.key")iferr!=nil{l

http - 如果内容长度错误,Chrome 会关闭 tcp 连接吗?

我对Web服务器对httpkeep-aliveheader的操作很感兴趣。所以我在httpserver的基础上搭建了一个简单的httpserver。服务器除了使用简单的htmlhttp正文响应客户端之外什么都不做。服务器代码在这里:packagemainimport("fmt""net""os")funcmain(){l,err:=net.Listen("tcp","localhost:9765")iferr!=nil{fmt.Println("Errorlistening:",err.Error())os.Exit(1)}deferl.Close()for{conn,err:=l.A

json - 使用原始 tcp 时确保完整消息传递的好方法是什么?

假设我有一个应用程序,我想在后端使用原始tcp,以便我可以在不同服务之间进行双向通信。在此应用程序中,我想发送一个由json对象组成的有效负载,当发送json数据时,每隔几条消息,它就会被切断,然后将其余部分聚集到下一个响应中。由于用于从http升级的时间,我不想使用像websockets这样的东西。什么是确保json对象从一个Node发出并作为wholejson对象从另一个Node读取的好方法(最好)?我知道发送和接收设置大小的缓冲区和心形信号的消息是经验法则,但我可以看一个例子吗?最好使用Javascript(node的netstdlib)或Golang(它是netstdlib),

c - 与 c 相比,Go 的二进制大小

这个问题在这里已经有了答案:ReasonforhugesizeofcompiledexecutableofGo(3个答案)关闭6年前。昨天我只是想比较简单的golangHelloWorld应用程序和c,gobinary是2-3MB(只是fmt.Println)然而,等效的C代码只有大约20kb(printf)。然后我检查了两个二进制文件正在执行的系统调用,使用strace;两者之间没有太大区别,所以你知道为什么golang二进制文件与等效的c语言相比如此庞大吗?

go - 向代理发送 TCP 数据包

我熟悉HTTP_PROXY并定义了一个DefaultTransport来代理HTTP请求。但是我找不到任何关于如何为TCP做同样的事情。这可能吗?还是必须依靠代理本身来转发数据包? 最佳答案 这是可能的,但不能使用HTTP代理。你想要一个SOCKS代理。查看https://godoc.org/golang.org/x/net/proxy提供SOCKS5拨号器的软件包。packagemainimport("fmt""os""golang.org/x/net/proxy")var(proxy_addr="my.socks.proxy.l

c - 从 Golang 中的 c 函数返回字符串

我正在尝试在GO中调用C函数。这适用于某些扩展(对于整数)。但是,存在问题下面给出了一个最小的例子packagemain/*#include#include#includevoidmy_reverse(char*src,intlen,char*dst){dst=malloc(sizeof(char)*(len+1));printf("[c-part]src=%s\n",src);for(inti=0;i这是两个c函数,它们在c中分配一个新的缓冲区。但是,我得到了输出[c-part]src=HelloWorld[c-part]dst=dlroWolleH[gopart]dst=willr